package drg_group.taizhou_2022.MDC;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

import drg_group.taizhou_2022.Base;
import drg_group.taizhou_2022.MedicalRecord;
import drg_group.taizhou_2022.ADRG.*;

public class MDCL{
    public static String group(MedicalRecord record){
        String[] mdc_zd={"D41.000x001","N34.000x005","D41.001","D41.101","T19.800x001","E11.201+N08.3*","E11.200x214+N08.3*","C68.100","M32.101+N08.5*","C90.005+N08.1*","Q60.400x001","N28.900x010","Q62.300x903","N32.201","N32.101","E10.200x016+N08.3*","N39.404","C68.805","C67.900x002","M31.003+N08.5*","Q62.301","Q62.700","R39.801","N30.902","E10.200x015+N08.3*","Q64.304","E11.200x024+N08.3*","N03.500x003","N28.004","N36.201","Q63.301","C90.004+N16.1*","R39.200","E14.200x031+N29.8*","N39.405","Q64.200x001","E14.200x212+N08.3*","N10.x01","N19.x03","Q61.100","R82.700","Q62.700x001","N25.803","S37.010","D30.900","N01.300x001","N25.001","Q60.500","E10.200x025+N08.3*","N04.300x003","R93.402","N28.804","N36.004","N36.806","Q61.404","C65.x00","E83.100x008+N16.3*","N18.902","N20.200x001","Q63.800x101","N13.901","N07.500","Q64.705","S37.300","Q64.700x902","N30.201","D41.301","S37.000x016","D30.301","E10.200x092+N08.3*","N28.818","N32.800x012","Q85.900x013","R82.900x003","N32.200","C79.000x001","C79.101","N28.813","R93.400x003","N25.804","N36.301","S37.300x082","Q85.903","N03.900","N30.800x004","N32.300","N34.203","D09.102","D41.200x001","N18.904","N23.x00","N13.503","N04.902","N12.x00","E10.200x212+N08.3*","N00.700","R94.400","C76.303","N28.826","Q62.100","Q64.600","C64.x00x004","C95.900x017+N16.1*","N04.101","Q62.201","T86.100x006","D21.506","N05.501","N01.900x001","Q62.101","S37.000x022","T83.004","N14.101","R30.900x001","Q64.700x201","N13.600x004","N25.900","N02.401","N05.801","Z46.602","R93.403","N39.900","Q61.200","Z49.000","I12.900x005","E14.200x011+N08.3*","Q61.000","N13.601","T83.100","N02.900x002","C79.001","N35.900","R39.000","D17.700x016","E14.200x027+N08.3*","N28.102","E10.200x030+N08.3*","T83.100x001","N13.603","N32.800x019","N28.822","C67.600","N05.802","E10.200x213+N08.3*","D30.400","M31.100","C68.801","N28.835","N03.801","T86.100x007","N99.100x005","Q62.103","S37.301","N03.300x001","S37.303","N21.001","E11.200x012+N08.3*","E12.200","N00.801","N05.000x004","N28.827","N28.823","N25.100","N17.200","N28.834","N28.801","N32.808","D41.700","N04.300x001","N15.101","E10.200x017+N08.3*","R80.x00x003","T19.000","N34.300","D18.000x811","N28.003","N28.900x026","N36.000x007","N36.302","N39.300x002","N39.800x001","N04.801","N02.302","N15.102","Q62.300x905","T86.106","Q62.500","T83.102","T83.001","N39.800","Z46.800x001","Q51.701","N05.600","N28.836","N13.302","R34.x01","Q62.100x802","N10.x00","T83.800x001","Q62.700x201","T83.100x004","N06.900","R82.902","Q61.402","N05.301","N04.800x002","Q64.401","N99.800x006","N31.200x006","Q62.202","N28.809","N31.800","N21.900","N31.901","Q27.305","E10.200x012+N08.3*","N36.005","N03.700","T86.102","N27.900","N03.900x006","Q63.001","S37.200x023","Q64.200x021","E66.902+N08.4*","S37.101","E85.411+N29.8*","N05.201","M35.006+N16.4*","N99.808","N28.901","T83.100x002","N00.900x008","N28.821","C48.001","N01.500x001","Q63.801","E14.200x029+N08.3*","E11.200x030+N08.3*","N14.102","N28.814","N39.100","N07.700","N13.701","R82.200","D41.100x001","R30.000","S37.111","Z45.800x007","N13.602","N11.900x001","R82.900x002","N32.002","C68.802","R82.500x005","N11.900","N28.805","C64.x00x001","C67.500","T83.002","N99.100","N02.102","Q85.900x029","N02.802","D09.103","N25.802","D09.101","N35.901","Q63.002","R39.100x001","C68.000","N31.202","S37.200x024","N20.000x002","N28.100","N30.809","C67.000","N15.901","E11.200x023+N08.3*","N03.601","E11.400x380+G99.0*","Q60.501","N13.202","N17.800","N14.201","T86.811","N00.301","N13.502","E10.200x031+N29.8*","E14.200x213+N08.3*","N03.900x007","T83.802","T19.100","E72.007","E85.403","N32.812","N35.000","Q64.708","E10.200x211+N08.3*","S37.000x012","Q64.700x904","N15.900x003","N01.100x002","N34.201","D41.300x001","Q61.401","N13.203","N13.400","E14.200x215+N08.3*","N30.100","N28.812","R80.x00","D09.104","C67.900","E11.200x026+N08.3*","E11.200x091+N08.3*","N17.000","N99.100x003","Q62.300x301","N28.820","T28.800","D30.701","Z49.000x002","N25.805","N39.402","N36.901","T86.104","D69.005+N08.2*","N32.802","N18.200","A40.901+N08.0*","A41.902+N08.0*","N07.600","N36.809","N32.301","N36.200","N32.104","R35.x00","E11.200x213+N08.3*","N20.900","N28.828","S37.000","S37.200","E10.200x023+N08.3*","S37.300x021","E11.200x011+N08.3*","M31.002+N08.5*","E11.200x029+N08.3*","N11.000x001","I86.201","Q63.101","C68.804","N12.x01","N13.201","C76.301","N31.200x003","R94.802","N99.500","S37.813","C66.x00x002","E14.200x025+N08.3*","Q60.600","T19.801","T83.500x002","N03.900x002","N02.301","D89.101+N08.2*","Q61.403","Q64.400x301","N03.000","N28.838","N00.900x009","N04.102","N32.810","C67.700","N13.506","N36.808","E72.006+N29.8*","N39.200","Q64.700x701","Q64.403","Q64.900","S37.011","C67.100","S37.300x081","T83.003","Q62.600","Q62.300x901","N13.600x001","E14.200x026+N08.3*","N17.901","Q63.102","C79.103","Q63.203","E10.200x024+N08.3*","N11.800x002","N32.813","E10.200x029+N08.3*","E11.200x013+N08.3*","N06.800","N32.800x008","T83.100x003","N28.900x004","I12.904","N32.801","N39.300","N32.809","N05.000x003","N18.901","N07.300","N26.x00","Q60.000","C79.100x002","Q62.300x902","Q63.302","Q62.300x101","C65.x02","E14.200x092+N08.3*","N20.000x003","N30.400","R32.x00","N28.819","R36.x01","E10.200x026+N08.3*","N28.811","N36.807","N03.900x004","R30.100x001","N11.801","N01.900x002","Q42.200x201","E14.200x023+N08.3*","E11.200x017+N08.3*","T86.100x001","N32.800x009","D41.400x001","N00.901","S37.814","N04.903","R82.500x006","E85.002","N14.400","N17.900","N01.200x001","N30.802","N32.901","R94.803","E13.200x521+N08.3*","M31.701+N08.5*","N05.900x009","R34.x02","Z46.603","S37.000x023","R93.405","E11.200x028+N08.3*","C95.900x007+N16.1*","N36.100","N18.400","N36.001","D30.302","Q64.700x601","T83.500x003","N28.815","S37.211","N02.900x001","N34.100","N04.400x001","N01.800","N18.501","S37.310","N13.600","N19.x02","N07.000","N02.600","N30.804","T86.105","N06.400","Q64.501","N02.101","M31.102+N08.5*","I12.900x003","N00.900x002","Q64.100","N00.800x001","N01.900","Q64.702","N34.200x006","R30.100","N28.902","N36.300","Q61.901","S37.000x032","N17.101","N28.005","R82.800","N36.804","E14.200x021+N08.3*","S37.000x013","E14.400x380+G99.0*","N11.800x003","N13.000","N13.604","R82.500x004","S37.300x031","E11.200x025+N08.3*","N34.101","N00.000","T83.200","N13.204","Q87.800x903","E10.200x091+N08.3*","N11.802","R93.400x001","R79.802","E13.201+N08.3*","N04.900","N13.501","C79.102","N34.000","S37.001","D09.100x001","N18.100","N34.102","N07.200","Z49.000x004","N17.200x003","R82.000","S37.200x081","I12.900x002","N04.200x001","N34.200x003","Q62.602","N00.900","E14.200x012+N08.3*","Z46.800x002","Q60.100","D30.100","N11.100","R82.500x003","Q62.400x002","N32.103","N32.814","N32.805","N03.503","N02.800x003","N39.401","N34.205","I12.000x001","N28.806","Q61.300","N35.000x001","N18.300","Q64.400x902","E14.200x016+N08.3*","M10.005+N22.8*","M31.703+N08.5*","N05.900","N12.x02","R82.500x007","N03.400","E11.200x215+N08.3*","N05.000x001","N99.001","T86.103","C68.800x003","R32.x01","Q64.200","N07.100","N02.900","N04.700","S37.002","C68.803","T83.501","N00.500","I12.900x006","E14.200x015+N08.3*","N01.600x001","N28.833","N00.900x006","S37.000x015","N03.100","N35.800","E14.400x381+N33.8*","Q64.502","Q87.808","C65.x01","N00.802","N01.000","E10.200x011+N08.3*","Q62.400","N04.501","N00.400","N28.900x013","N13.600x002","E14.200x091+N08.3*","E14.200x024+N08.3*","N11.900x003","N05.900x006","N06.100","N28.831","C67.300","R30.000x002","S37.300x004","N28.803","Q63.800x902","Q62.601","N05.101","N13.300x005","Q60.300","E11.200x014+N08.3*","Q62.800","T28.800x001","N06.001","E14.200x013+N08.3*","N30.000","R94.402","C67.200","N25.004","T86.100x003","N03.502","N36.000","R39.100x002","R82.901","N17.900x002","N31.201","N99.101","N20.002","N34.200x004","N32.000","Q61.800","A02.205+N16.0*","N05.701","N30.901","N14.000","N03.900x005","N32.203","N28.825","T86.100x008","I12.900x001","N28.810","C67.501","E11.400x381+N33.8*","C67.400","T86.100x002","N02.702","N05.900x003","N17.200x002","N28.817","N15.900x004","N05.400","R80.x02","N32.800x014","Q64.700x901","Q60.200","N28.900x017","N28.837","N18.900x011","Q60.400","R82.300","N31.200x002","N31.203","N30.808","R35.x00x003","N01.700x001","T83.800","N01.400x001","N03.800x004","N32.100","N99.000","Q64.701","S37.300x011","N31.100x001","N02.502","Q63.000","N02.203","Q61.801","N10.x02","N28.808","Q61.400","N30.807","N00.902","N32.811","R31.x00","N30.300","Q63.201","N28.001","N36.803","E10.200x014+N08.3*","N30.801","N25.800x006","N99.805","T79.500x002","E14.200x028+N08.3*","D30.000","S37.302","N36.802","N32.202","C68.800","N20.100","T81.800x011","N25.806","T28.300","M32.102+N16.4*","C66.x00x003","S37.000x031","E11.200x015+N08.3*","N32.803","I12.900x008","Z49.101","N13.504","E10.200x214+N08.3*","N15.900x002","Q64.703","N34.202","E11.200x016+N08.3*","N03.800x003","D41.401","N04.601","N06.500","N99.803","T83.101","N28.830","N34.204","Q62.100x902","N14.301","Q62.400x001","E14.200x030+N08.3*","N03.800x001","N99.806","R93.404","T81.800x014","N04.901","N20.000","N28.800x001","N19.x01","Q64.302","N36.003","Q62.700x101","N36.805","E10.200x013+N08.3*","N20.900x001","E14.200x017+N08.3*","D41.400x004","N35.100x001","N06.200","Q64.707","N32.806","N30.810","T86.100x005","Z49.201","M31.305+N08.5*","N02.002","E11.200x212+N08.3*","Z46.600x001","D18.000x819","E10.201+N08.3*","T83.000x001","I12.900x009","Q64.704","N21.000","N02.201","N20.001","N32.800x003","Q64.402","Z52.400","N05.803","N28.824","N31.000x001","D41.901","N17.002","N13.500x010","N28.839","Q62.104","N19.x00","Z46.601","R93.401","D09.000","N00.600","R82.600x001","N05.900x007","Q61.900","N26.x02","E10.200x028+N08.3*","N03.901","N30.805","Q62.300x904","S37.004","N20.000x001","Q62.000","N06.600","T83.500","D41.900x001","N06.300","N34.002","N99.800x011","Q62.200","D18.000x806","N05.900x002","N13.605","N17.900x004","N39.000","Q64.100x091","Q64.303","S37.201","T79.500","N32.807","N34.001","E11.200x211+N08.3*","E11.200x027+N08.3*","N03.200x001","I13.100x001","E14.200x211+N08.3*","N04.001","N32.815","N15.000","R94.401","S37.003","S37.200x011","T83.804","Q64.700x801","E14.200x214+N08.3*","N01.900x003","B65.002+N22.0*","N02.701","N02.801","N17.001","N32.900x002","N39.001","R80.x01","N31.200x001","N32.001","E14.200x014+N08.3*","N13.801","N03.900x003","S37.100","S37.300x083","N07.400","D30.300","R39.200x001","N00.100x001","Q64.000","N36.002","D30.200","D41.201","N20.901","E11.200x092+N08.3*","N30.806","N31.200x007","Q63.103","T86.107","N11.901","N30.803","E10.200x215+N08.3*","N15.801","Q64.301","N32.804","M10.001+N16.8*","E11.200x031+N29.8*","N04.502","N12.x03","N17.900x003","N13.100x001","N21.800","N28.832","N06.700","N28.829","N02.001","N27.100","N30.900","E10.200x027+N08.3*","N18.500","N32.204","N13.301","N00.200","R35.x00x001","N03.501","R39.101","C66.x00","N28.002","T19.900","N21.100","N28.802","N28.807","C64.x00x003","Q61.500","R33.x00","R93.400x002","S37.300x005","Q64.800x001","C68.900","C67.800","N26.x01","N28.101","N39.403","S37.200x022","N32.102","T83.103","N07.900x001","Q63.900","T83.801","N17.100","N39.400","M35.007+N16.4*","Q63.200","N27.000","N07.800","N32.400","Q64.706","N28.816"};
        String[] dept_list={};
        if (!(true && Base.contains(mdc_zd,record.zdList[0]))){
            return "";
        }
        
        Base.groupMessages.putMessage(record.Index,"符合MDCL入组条件，匹配规则：主诊断匹配");
        String result;

        result=LA1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LA2.group(record);
        if (result.length()>0){
            return result;
        }

        result=LB1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LB2.group(record);
        if (result.length()>0){
            return result;
        }

        result=LC1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LD1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LE1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LF1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LJ1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LL1.group(record);
        if (result.length()>0){
            return result;
        }

        if (false && record.ssList!=null && record.ssList.length>0  && Base.intersect(Base.SS_VALID,record.ssList)){
            Base.groupMessages.putMessage(record.Index,"符合LQY入组条件，存在有效手术操作："+String.join(",",Base.Intersect(record.ssList,Base.SS_VALID)));
            return "LQY";
        }

        result=LR1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LS1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LT1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LU1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LV1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LW1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LX1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LZ1.group(record);
        if (result.length()>0){
            return result;
        }

        Base.groupMessages.putMessage(record.Index,"不符合MDCL的ADRG入组条件");
        return "";
    }
}

